const path = require( 'path' );
const { VueLoaderPlugin } = require( 'vue-loader' );
/**
 * umd 组件全打包
 */
module.exports = {
  mode: 'production',
  entry: path.resolve( __dirname, '../packages/fow-code-ui/index.ts' ),
  output: {
    path: path.resolve( __dirname, '../lib' ),
    filename: 'index.js',
    libraryTarget: 'umd', // 可以支持commonjs 和 amd  不支持es6 可以在浏览器直接使用
    library: 'FowCodeUi'
  },
  externals: {
    vue: { // 忽略组件引用的vue变量
      root: 'Vue',
      commonjs: 'vue',
      commonjs2: 'vue'
    }
  },
  resolve: { // 解析模块 对应的扩展名有哪些
    extensions: [ '.ts', '.tsx', '.js', '.vue' ]
  },
  module: {
    rules: [ {
      test: /\.(ts|js)x?$/,
      exclude: /node_modules/,
      loader: 'babel-loader'
    },
    {
      test: /\.vue$/,
      loader: 'vue-loader'
    }
    ]
  },
  plugins: [
    new VueLoaderPlugin(),
  ]
}
